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Field of the Invention 



The present invention is in the area of data packet routers for use 
with wide-area networks, such as the Internet, and pertains more 
particularly to Automatic Protection Switching (APS) within such routers. 



At the time of the present patent application demand for increased 
data capacity and efficiency in Internet traffic continues to increase 
dramatically as more individuals and businesses increase their use of the 
Internet. The ever-increasing demand also drives development of 
equipment for the Internet such as data packet routers. A number of 
enterprises are developing routers that are capable of faster and higher 
capacity handling of data packets. 

The Internet, operating globally, comprises components from a wide 
variety of companies and organizations. It is, of course, necessary that such 
equipment conform to certain hardware and connection standards and 
operate by certain data transfer standards and protocols. These standards 
are all well known to the skilled artisan. 

As new and better equipment for routing data traffic in the Internet 
continues to be developed, researchers developing such equipment are 
including fault tolerance, diagnostic capabilities, and redundancy into the 



Background of the Invention 




equipment, links between instances of routing equipment, and in routing 
protocols. At the time of the present patent application, for example, there 
exist redundancy systems for data traffic between routers, generally termed 
Automatic Protection Switching (APS) in the art. APS is described in more 
5 detail as it exists in the art below, under the section entitled "Description of 
the Preferred Embodiments". 

One of the important developments in Internet technology as of the 
time of filing of the present patent application is in development of faster, 
and scalable routers. The present inventors, for example, are involved in 

10 development of what are known in the art as Terabit routers, capable of 
much higher packet transfer rates than currently available in the art. 

It is highly desirable in new and faster routers to make very quick 
switchover to alternate routing paths if there should be a failure, impeding 
flow of data packets. The need for quick reaction is quite simply the fact 

15 that many packets (much data) is lost with slower switchover. It is 

therefore desirable to have a quick hardware temporary solution in the event 
of component failure, followed by a more complete software solution, and 
then eventual repair. It is to this need for quick reaction to partial failure in 
routers, that is, failure of individual paths and components, to which the 

20 present application is addressed. The inventors have developed apparatus 
and methods for addressing this need. 

Summary of the Invention 

25 In a preferred embodiment of the present invention a method is 

provided for redirecting packets received in a line card in a data packet 
router, the packets received by fabric interface circuitry on the line card and 
destined for a port on the line card. A preferred embodiment comprises the 
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steps of monitoring port status by a CPU on the line card, updating of 
information in the fabric interface circuitry by the CPU listing port status as 
active or failed and an alternative destination for each port, checking the 
table by the interface circuitry for a packet received, and sending the 
received packet to the predestined port if the port is listed in the table as 
active, and sending the received packet to the alternative destination if the 
port is listed in the table as failed. In another embodiment a method is 
provided wherein the fabric interface circuitry comprises one or more 
Global Fabric application-specific integrated circuits (GFRs). 

In another embodiment a method is provided wherein the line card 
comprises four external ports and two GFRs. In another embodiment a 
method is provided wherein the operations of the interface circuitry in the 
steps of checking the table by the interface circuitry for a packet received, 
and sending the received packet to the predestined port if the port is listed in 
the table as active, and sending the received packet to the alternative 
destination if the port is listed in the table as failed, are implemented in 
hardware logic. In another embodiment a method is provided wherein, 
during the step of sending the received packet to the predestined port if the 
port is listed in the table as active, and sending the received packet to the 
alternative destination if the port is listed in the table as failed, a fabric 
interface circuit on an alternate line card is the alternative destination. In 
another embodiment a method for redirecting packets is provided wherein 
pre-destinations and alternative destinations are noted by destination tags 
associated with packets in process. 

In another aspect of the invention a router line card is provided, the 
card enabled for Automatic Protection Switching and comprising multiple 
external port circuits connecting to external transmission links, a CPU, one 
or more fabric interface circuits connecting to router fabric cards, and 



• ... • 



interconnect circuitry on the line card interconnecting the port circuits, the 
CPU and the fabric interface circuits. The card is characterized in that the 
CPU monitors the ports and updates information in the fabric interface 
circuits for ports active or failed, and the fabric interface circuits check 
5 predestination for each packet received from the fabric, and redirect all 
packets predestined for failed ports. In another embodiment a router line 
card is provided having a fabric interface circuitry comprising of one or 
more Global Fabric application-specific integrated circuits (GFRs). 

In some other embodiments a router line card comprises of four 
□ 10 external ports and two GFRs, or has steps wherein the operations of the 

.5* interface circuitry are implemented in hardware logic. In other 

: a? : 

\*\ embodiments a router line card has a fabric interface circuit on an alternate 

ill line card as an alternative destination for a redirected packet, and has pre- 

^ destinations and alternative destinations noted by destination tags associated 

^ 15 with packets in process. 

•Q In another preferred embodiment a data packet router is provided 

; ~ having line cards internally connected by fabric circuitry, wherein 

Q individual ones of the line cards comprise multiple external port circuits 

~ connecting to external transmission links, a CPU, one or more fabric 

20 interface circuits connecting to router fabric cards, and circuitry 

interconnecting the port circuits, the CPU and the fabric interface circuits. 
In a preferred embodiment the method is characterized in that the CPU on 
individual ones of the line cards monitor the ports and update information in 
the fabric interface circuits for ports active or failed, and the fabric interface 
25 circuits check predestination for each packet received from the fabric, and 
redirect all packets predestined for failed ports. In another embodiment a 
data packet router can have fabric interface circuitry comprising one or 
more Global Fabric application-specific integrated circuits (GFRs). In 



some other embodiments a data packet router comprises four external ports 
and two GFRs, and logic in the GFRs may be implemented in hardware. In 
other embodiments a data packet router has a fabric interface circuit on an 
alternate line card as an alternative destination for a redirected packet, and 
has pre-destinations and alternative destinations noted by destination tags 
associated with packets in process. 

In all the preferred embodiments of the invention improved method 
and apparatus is provided allowing new and faster data packet processing 
hardware to make very quick switchover to alternate routing paths, 
providing an improved solution to lost data caused by slower switching 
during a component failure. 



Brief Description of the Drawing Figures 

Fig. 1 is a block diagram of a prior art situation, illustrating 
redundant switching between two routers in the Internet network. 

Fig. 2 is a block diagram also labeled prior art showing two edge 
routers in the Internet connected to a ring of ADM machines. 

Fig. 3 is a block diagram also labeled prior art illustrating additional 
detail of ADM architecture. 

Fig. 4 is a block diagram illustrating a router configuration 
according to an embodiment of the present invention. 

Fig. 5 is a block diagram illustrating more detail of a router 
configuration and second line card according to an embodiment of the 
present invention. 

Fig. 6 is a table showing ports and associated line items for the first 
line card of Fig. 5. 
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Description of the Preferred Embodiments 



Fig. 1 is a block diagram of a prior art situation, illustrating 
redundant switching between two routers in the Internet network. Fig. 1 is 
5 intended to describe the very general problems that might occur in the 

Internet between two routers 1 1 and 13, wherein there is a primary link 15, 
labeled primary, between an interface 1 (17) on router 1 and an interface 1 
(19) on router 2. This primary connection transfers data in both directions, 
as is indicated by the two-way arrows. In the event there is an equipment 

10 failure, software failure, routing path failure, or some other sort of failure, 
that effects the ability of the primary link to transfer data, there needs to be 
some form of redundancy. Such a failure can be complete, such as a break 
in an optic cable, or partial, such as a failure of one or more ports on a line 
card serving a link. 

15 When a failure or partial failure occurs, such as described 

immediately above, there needs to be a method and protocol for switching 
the traffic from the primary link to a secondary, or redundant link, such as 
link 21 shown in Fig. 1, between two different interfaces labeled INT 2 on 
each of routers 1 1 and 13, and labeled also as elements 23 and 25. This 

20 switchover needs to happen very quickly, because all packets in process at 
either router for transfer by the primary link (15) will typically be lost 
(dropped) until the switchover takes place. 

There is in the current art a fiber optic standard known as the 
SONET standard, which defines considerable standard and protocol for 

25 error correction, failure switching, and so forth, for taking care of just these 
kinds of failures, and for quickly compensating for such failures. These 
protocols operate on what are known as SONET boxes in the art, which are 
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routing boxes built to, and operating by SONET standards. These boxes do 
not encompass all Internet routers. 

Fig. 2 is a prior art diagram showing a ring 27 of Add-Drop 
Multiplexers (ADM) with two routers 3 1 and 33 connected to the ring. This 
5 diagram illustrates the general and typical connection schematic for router 
interconnection in the Internet, wherein edge routers are connected to 
individual users, for example, and ADM boxes are used for more core 
transmission applications. The ADM boxes are SONET devices. 

Fig. 3 is a block diagram illustrating additional detail of architecture 
□ 10 of a SONET box 35, such as an ADM, in particular on what is known as the 

m line side; that is the side interfacing to transmission lines or links. A Framer 

39 on a line card 37 interfaces through both input and output paths to a 

: e : 

fS number of port cards (PC) 4 1 . Data out from the framer through port cards 

^ goes to remote destinations, and data coming in from remote destinations 

l] _ 15 through other port cards is transferred via a multiplexer 43 to framer 39. 

=fl APS is implemented in the art by switching data from primary port cards to 

\Z redundant port cards. 

• — x 

Q Fig. 4, also labeled prior art, is a block diagram illustrating a router 

i'szj 

44, such as a terabit scalable router that may be used as an edge router, such 
20 as routers 3 1 and 33 in Fig. 2. There are 5 line cards 45, 47, 49, 5 1 and 53 

shown for router 44 in Fig. 4, interconnected in the router by switching 

fabric 55. Each of line cards 45-53 typically has on-card ports, which may 

be, for example, OC-48c ports known as Packet Processing ASICs (PPAs). 

The fact that there are no port cards in these routers that are not SONET 
25 boxes is an important reason why it is difficult to provide truly rapid 

protection switching. 

In a preferred embodiment of the present invention the inventors 

have provided automatic protection switching at the level of ports (PPAs) 
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on line cards within an individual router. Fig. 5 is a block diagram 
illustrating more detail of a single line card of router 44 of Fig. 4, and a 
second line card 47. In this example, any two of the line cards of the router 
of Fig. 4 will serve. The switching fabric is element 55. Line card 45 has a 
CPU 57, interconnect structure 59, and four active ports 60-63 labeled Pt 0 
through Pt 3 . Each port represents a PP A. The standby port could be on the 
same line card as the active ports or ports it protects. 

The fabric interface for the active line card is an application-specific 
integrated circuit (ASIC) termed a Global Fabric ASIC and referred to by 
the inventors by the acronym GFR. In a particular embodiment there are 
four PPAs on the line card, as shown, each capable of data transfer at 2.5 
Gb/s, so the line card is capable of overall data transfer of 10 Gb/s. Each 
line card in this example has two GFR ASICs, labeled in Fig. 5 as GFRs 65 
and 67, for redundancy and performance. 

In operation, each GFR on an active line card connects to a fabric 
card in the fabric structure 55. Data packets being sent into the fabric from 
a line card are tagged in operations of elements on the line card, in this case 
typically with a four digit decimal number (which may, of course be 
rendered in HEX or binary for computing purposes), designating the router 
destination, and data packets received from the fabric at a GFR come with 
tags for the GFR receiving them. 

In a preferred embodiment of the present invention CPU 57 on 
active line card 45, following a code sequence, monitors the PPAs, such as 
PPAs 60-63 on the line card for performance to a standard. This monitoring 
may be on a continuous or a semi-continuous basis (periodic). Also in this 
embodiment each GFR stores a port-status table, shown in simplified form 
in Fig. 6, with a line item for at least each port on the active card. In 
embodiments of the invention such a table may be stored elsewhere than on 



a GFR, such as on a PPA, on a fabric card, or elsewhere, as long as access 
may be made to the port-status table. 

Three columns are shown in the table of Fig. 6, a first column 
indicating each port on the card, a second column with an entry for whether 
5 the port is active (meets performance standard) or faulty, and a third column 
with a redirect tag number. The status column may be a single bit, for 
example, with a 1 indicating active and a 0 indicating fault (or vice versa), 
and the redirect tag is a destination tag for a standby port for each port. In 
some cases the redirect will be the same for all line entries, and in other 

10 cases the redirect may be different for each line entry. 

On a packet-by-packet basis, as each packet comes into the active 
line card from the fabric, the receiving GFR checks the table for fault status. 
If the port is active, the packet goes on to the port. If the status is fault, the 
GFR replaces the existing tag with the redirect tag, and the packet is 

15 bounced back into the fabric and on to the line card 47 which in this case 
has the standby port. 

In operation before the advent of this invention, status could be 
monitored, and forwarding tables updated on a regular basis, but the process 
was much too slow to avoid loss of significant quantities of packets. With 

20 the redirect tables in the GFRs and PPAs and redirecting packets 

immediately as the CPU notices faults, packets that would otherwise be lost 
are redirected and therefore saved. If it is desired to replace the line card 
with the failed port, the forwarding tables may be updated to direct all 
traffic away from that line card. Then the line card may be conveniently 

25 replaced. 

In an alternative embodiment of the present invention the techniques 
described above related to GFRs on line cards can also be applied within an 
interconnection network, or fabric, connecting multiple line cards or 




interfaces. For example, by updating a port redirect table in each fabric 
element which connects to a line card, those fabric elements can redirect all 
traffic destined for ports on that line card. 

It will be apparent to the skilled artisan that there are many 
alterations that might be made in embodiments of the inventions described 
herein within the spirit and scope of the invention. For example, there are 
different ways the necessary code may be generated, and different ways the 
invention may be managed in different line cards in different routers. There 
are many other possible alterations, and the invention should accordingly 
be granted the scope of the claims that follow. 



